<template>
  <div class="app-container" style="max-height:85vh;overflow: auto;">
    <el-row>
      <el-col :span="12" class="card-box">
        <el-card>
          <div slot="header"><span>
            <!-- CPU -->
            {{ $t('server.table.cpu.title') }}
            </span></div>
          <div class="el-table el-table--enable-row-hover el-table--medium">
            <table cellspacing="0" style="width: 100%;">
              <thead>
                <tr>
                  <th class="is-leaf">
                    <div class="cell">
                      <!-- 属性 -->
                      {{ $t('server.table.cpu.attribute') }}
                    </div>
                  </th>
                  <th class="is-leaf">
                    <div class="cell">
                      <!-- 值 -->
                       {{ $t('server.table.cpu.value') }}
                    </div>
                  </th>
                </tr>
              </thead>
              <tbody>
                <tr>
                  <td>
                    <div class="cell">
                      <!-- 核心数 -->
                       {{ $t('server.table.cpu.center') }}
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.cpu">
                      {{ server.cpu.cpuNum }}
                    </div>
                  </td>
                </tr>
                <tr>
                  <td>
                    <div class="cell">
                      <!-- 用户使用率 -->
                      {{ $t('server.table.cpu.user') }}
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.cpu">
                      {{ server.cpu.used }}%
                    </div>
                  </td>
                </tr>
                <tr>
                  <td>
                    <div class="cell">
                      <!-- 系统使用率 -->
                     {{ $t('server.table.cpu.system') }}
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.cpu">
                      {{ server.cpu.sys }}%
                    </div>
                  </td>
                </tr>
                <tr>
                  <td>
                    <div class="cell">
                      <!-- 当前空闲率 -->
                      {{ $t('server.table.cpu.now') }}
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.cpu">
                      {{ server.cpu.free }}%
                    </div>
                  </td>
                </tr>
              </tbody>
            </table>
          </div>
        </el-card>
      </el-col>

      <el-col :span="12" class="card-box">
        <el-card>
          <div slot="header">
            <span>
              <!-- 内存 -->
              {{ $t('server.table.store.title') }}
            </span>
          </div>
          <div class="el-table el-table--enable-row-hover el-table--medium">
            <table cellspacing="0" style="width: 100%;">
              <thead>
                <tr>
                  <th class="is-leaf">
                    <div class="cell">
                      <!-- 属性 -->
                        {{ $t('server.table.store.attribute') }}
                    </div>
                  </th>
                  <th class="is-leaf">
                    <div class="cell">
                      <!-- 内存 -->
                      {{ $t('server.table.store.memory') }}
                    </div>
                  </th>
                  <th class="is-leaf"><div class="cell">JVM</div></th>
                </tr>
              </thead>
              <tbody>
                <tr>
                  <td>
                    <div class="cell">
                      <!-- 总内存 -->
                      {{ $t('server.table.store.sum') }}
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.mem">
                      {{ server.mem.total }}G
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.jvm">
                      {{ server.jvm.total }}M
                    </div>
                  </td>
                </tr>
                <tr>
                  <td>
                    <div class="cell">
                      <!-- 已用内存 -->
                      {{ $t('server.table.store.used') }}
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.mem">
                      {{ server.mem.used }}G
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.jvm">
                      {{ server.jvm.used }}M
                    </div>
                  </td>
                </tr>
                <tr>
                  <td>
                    <div class="cell">
                      <!-- 剩余内存 -->
                      {{ $t('server.table.store.remain') }}
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.mem">
                      {{ server.mem.free }}G
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.jvm">
                      {{ server.jvm.free }}M
                    </div>
                  </td>
                </tr>
                <tr>
                  <td>
                    <div class="cell">
                      <!-- 使用率 -->
                       {{ $t('server.table.store.use') }}
                    </div>
                  </td>
                  <td>
                    <div
                      class="cell"
                      v-if="server.mem"
                      :class="{ 'text-danger': server.mem.usage > 80 }"
                    >
                      {{ server.mem.usage }}%
                    </div>
                  </td>
                  <td>
                    <div
                      class="cell"
                      v-if="server.jvm"
                      :class="{ 'text-danger': server.jvm.usage > 80 }"
                    >
                      {{ server.jvm.usage }}%
                    </div>
                  </td>
                </tr>
              </tbody>
            </table>
          </div>
        </el-card>
      </el-col>

      <el-col :span="24" class="card-box">
        <el-card>
          <div slot="header">
            <span>
              <!-- 服务器信息 -->
              {{ $t('server.table.information.title') }}
            </span>
          </div>
          <div class="el-table el-table--enable-row-hover el-table--medium">
            <table cellspacing="0" style="width: 100%;">
              <tbody>
                <tr>
                  <td>
                    <div class="cell">
                      <!-- 服务器名称 -->
                      {{ $t('server.table.information.name') }}
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.sys">
                      {{ server.sys.computerName }}
                    </div>
                  </td>
                  <td>
                    <div class="cell">
                      <!-- 操作系统 -->
                      {{ $t('server.table.information.system') }}
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.sys">
                      {{ server.sys.osName }}
                    </div>
                  </td>
                </tr>
                <tr>
                  <td>
                    <div class="cell">
                      <!-- 服务器IP -->
                      {{ $t('server.table.information.ip') }}
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.sys">
                      {{ server.sys.computerIp }}
                    </div>
                  </td>
                  <td>
                    <div class="cell">
                      <!-- 系统架构 -->
                      {{ $t('server.table.information.framework') }}
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.sys">
                      {{ server.sys.osArch }}
                    </div>
                  </td>
                </tr>
              </tbody>
            </table>
          </div>
        </el-card>
      </el-col>

      <el-col :span="24" class="card-box">
        <el-card>
          <div slot="header">
            <span>
              <!-- Java虚拟机信息 -->
              {{ $t('server.table.java.title') }}
            </span>
          </div>
          <div class="el-table el-table--enable-row-hover el-table--medium">
            <table cellspacing="0" style="width: 100%;">
              <tbody>
                <tr>
                  <td>
                    <div class="cell">
                      <!-- Java名称 -->
                      {{ $t('server.table.java.name') }}
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.jvm">
                      {{ server.jvm.name }}
                    </div>
                  </td>
                  <td>
                    <div class="cell">
                      <!-- Java版本 -->
                      {{ $t('server.table.java.version') }}
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.jvm">
                      {{ server.jvm.version }}
                    </div>
                  </td>
                </tr>
                <tr>
                  <td>
                    <div class="cell">
                      <!-- 启动时间 -->
                      {{ $t('server.table.java.startTime') }}
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.jvm">
                      {{ server.jvm.startTime }}
                    </div>
                  </td>
                  <td>
                    <div class="cell">
                      <!-- 运行时长 -->
                      {{ $t('server.table.java.run') }}
                    </div>
                  </td>
                  <td>
                    <div class="cell" v-if="server.jvm">
                      {{ server.jvm.runTime }}
                    </div>
                  </td>
                </tr>
                <tr>
                  <td colspan="1">
                    <div class="cell">
                      <!-- 安装路径 -->
                      {{ $t('server.table.java.install') }}
                    </div>
                  </td>
                  <td colspan="3">
                    <div class="cell" v-if="server.jvm">
                      {{ server.jvm.home }}
                    </div>
                  </td>
                </tr>
                <tr>
                  <td colspan="1">
                    <div class="cell">
                      <!-- 项目路径 -->
                      {{ $t('server.table.java.item') }}
                    </div>
                  </td>
                  <td colspan="3">
                    <div class="cell" v-if="server.sys">
                      {{ server.sys.userDir }}
                    </div>
                  </td>
                </tr>
              </tbody>
            </table>
          </div>
        </el-card>
      </el-col>

      <el-col :span="24" class="card-box">
        <el-card>
          <div slot="header">
            <span>
              <!-- 磁盘状态 -->
              {{ $t('server.table.disk.title') }}
            </span>
          </div>
          <div class="el-table el-table--enable-row-hover el-table--medium">
            <table cellspacing="0" style="width: 100%;">
              <thead>
                <tr>
                  <th class="is-leaf">
                    <div class="cell">
                      <!-- 盘符路径 -->
                      {{ $t('server.table.disk.path') }}
                    </div>
                  </th>
                  <th class="is-leaf">
                    <div class="cell">
                      <!-- 文件系统 -->
                      {{ $t('server.table.disk.file') }}
                    </div>
                  </th>
                  <th class="is-leaf">
                    <div class="cell">
                      <!-- 盘符类型 -->
                      {{ $t('server.table.disk.type') }}
                    </div>
                  </th>
                  <th class="is-leaf">
                    <div class="cell">
                      <!-- 总大小 -->
                        {{ $t('server.table.disk.sum') }}
                    </div>
                  </th>
                  <th class="is-leaf">
                    <div class="cell">
                      <!-- 可用大小 -->
                       {{ $t('server.table.disk.sum') }}
                    </div>
                  </th>
                  <th class="is-leaf">
                    <div class="cell">
                      <!-- 已用大小 -->
                      {{ $t('server.table.disk.used') }}
                    </div>
                  </th>
                  <th class="is-leaf">
                    <div class="cell">
                      <!-- 已用百分比 -->
                      {{ $t('server.table.disk.percent') }}
                    </div>
                  </th>
                </tr>
              </thead>
              <tbody v-if="server.sysFiles">
                <tr v-for="(sysFile, index) in server.sysFiles" :key="index">
                  <td>
                    <div class="cell">{{ sysFile.dirName }}</div>
                  </td>
                  <td>
                    <div class="cell">{{ sysFile.sysTypeName }}</div>
                  </td>
                  <td>
                    <div class="cell">{{ sysFile.typeName }}</div>
                  </td>
                  <td>
                    <div class="cell">{{ sysFile.total }}</div>
                  </td>
                  <td>
                    <div class="cell">{{ sysFile.free }}</div>
                  </td>
                  <td>
                    <div class="cell">{{ sysFile.used }}</div>
                  </td>
                  <td>
                    <div
                      class="cell"
                      :class="{ 'text-danger': sysFile.usage > 80 }"
                    >
                      {{ sysFile.usage }}%
                    </div>
                  </td>
                </tr>
              </tbody>
            </table>
          </div>
        </el-card>
      </el-col>
    </el-row>
  </div>
</template>

<script>
import { getServer } from '@/api/monitor/server'

export default {
  name: 'Server',
  data () {
    return {
      // 加载层信息
      loading: [],
      // 服务器信息
      server: []
    }
  },
  created () {
    this.getList()
    this.openLoading()
  },
  methods: {
    /** 查询服务器信息 */
    getList () {
      getServer().then(response => {
        this.server = response.data
        // console.log(this.server)
        this.loading.close()
      })
    },
    // 打开加载层
    openLoading () {
      this.loading = this.$loading({
        lock: true,
        text: '拼命读取中',
        spinner: 'el-icon-loading',
        background: 'rgba(0, 0, 0, 0.7)'
      })
    }
  }
}
</script>
